package org.hzz.promotions.domain.entity;

import io.gitee.pkmer.ddd.shared.Entity;
import lombok.experimental.Accessors;
import org.hzz.promotions.types.enums.coupon.CouponStatus;
import org.hzz.promotions.types.enums.coupon.DiscountType;
import org.hzz.promotions.types.enums.coupon.ObtainWay;
import lombok.Data;

import java.time.LocalDateTime;

/**
 * @author <a href="mailto:1193094618@qq.com">pkmer</a>
 * <br>
 * <a href = "https://gitee.com/pkmer/sonatype-central-publisher">Code Repository</a>
 * At 2024/8/29
 */
@Data
@Accessors(chain = true)
public class CouponEntity implements Entity {
    private Long id;

    // 优惠券名称，可以和活动名称保持一致
    private String name;

    // 优惠券类型，1：普通券。目前就一种，保留字段
    private Byte type;

    // 折扣类型，1：满减，2：每满减，3：折扣，4：无门槛
    private DiscountType discountType;

    // 是否限定作用范围，false：不限定，true：限定。默认false
    private Boolean specific;

    // 折扣值，如果是满减则存满减金额，如果是折扣，则存折扣率，8折就是存80
    private Integer discountValue;

    // 使用门槛，0：表示无门槛，其他值：最低消费金额
    private Integer thresholdAmount;

    // 最高优惠金额，满减最大，0：表示没有限制，不为0，则表示该券有金额的限制
    private Integer maxDiscountAmount;

    // 获取方式：1：手动领取，2：兑换码
    private ObtainWay obtainWay;

    // 开始发放时间
    private LocalDateTime issueBeginTime;

    // 结束发放时间
    private LocalDateTime issueEndTime;

    // 优惠券有效期天数，0：表示有效期是指定有效期的
    private Integer termDays;

    // 优惠券有效期开始时间
    private LocalDateTime termBeginTime;

    // 优惠券有效期结束时间
    private LocalDateTime termEndTime;

    // 优惠券配置状态，1：待发放，2：未开始   3：进行中，4：已结束，5：暂停
    private CouponStatus status;

    // 总数量，不超过5000
    private Integer totalNum;

    // 已发行数量，用于判断是否超发
    private Integer issueNum;

    // 已使用数量
    private Integer usedNum;

    // 每个人限领的数量，默认1
    private Integer userLimit;

    // 创建时间
    private LocalDateTime createTime;

    // 更新时间
    private LocalDateTime updateTime;

    // 创建人
    private Long creater;

    // 更新人
    private Long updater;

    // 拓展参数字段，保留字段
    private String extParam;
}
